// pages/goods_list/index.js
import { request } from "../../request/index.js";
import regeneratorRuntime from '../../lib/runtime/runtime';
Page({

    /**
     * 页面的初始数据
     */

    data: {
        tabs: [{
                id: 0,
                value: "综合",
                isActive: true
            },
            {
                id: 1,
                value: "销量",
                isActive: false
            },
            {
                id: 2,
                value: "价格",
                isActive: false
            }
        ],
        goodsList: []

    },
    // 接口参数
    QueryParams: {
        query: "",
        cid: "",
        pagenum: 1,
        pagesize: 10
    },
    // 总页数
    totalPages: 1,


    onLoad: function(options) {
        this.QueryParams.cid = options.cid || "";
        this.QueryParams.query = options.query || "";
        // console.log(options);
        this.getGoodsList();

    },

    // 获取商品列表数据
    async getGoodsList() {
        const res = await request({ url: "/goods/search", data: this.QueryParams });
        // 获取 总条数
        const total = res.total;
        // 计算总页数
        this.totalPages = Math.ceil(total / this.QueryParams.pagesize);

        this.setData({
                // 拼接了数组
                goodsList: [...this.data.goodsList, ...res.goods]
            })
            // 关闭下拉刷新的窗口 如果没有调用下拉刷新的窗口 直接关闭也不会报错  

        wx.stopPullDownRefresh();
    },

    handleTabsItemChange(e) {
        // 1 获取被点击的标题索引
        const { index } = e.detail;
        // 2 修改源数组
        let { tabs } = this.data;
        // console.log(tabs);
        tabs.forEach((v, i) => i === index ? v.isActive = true : v.isActive = false);
        // 3 赋值到data中
        this.setData({
            tabs
        })

    },
    // 页面上滑 滚动条触底事件
    onReachBottom() {
        //  1 判断还有没有下一页数据
        if (this.QueryParams.pagenum >= this.totalPages) {
            wx.showToast({ title: '没有了0.0' });
        } else {
            this.QueryParams.pagenum++;
            this.getGoodsList();
        }
    },

    // 下拉刷新事件
    onPullDownRefresh() {
        // 重置数组
        this.setData({
                goodsList: []
            })
            // 重置页码
        this.QueryParams.pagenum = 1;
        // 发送请求
        this.getGoodsList();
    }


})